home *** CD-ROM | disk | FTP | other *** search
/ Amiga Plus 1995 #5 & #6 / Amiga Plus CD - 1995 - No. 5 and 6.iso / pd / netz / term / extras / source / term-source.lha / termPickScreen.c < prev    next >
C/C++ Source or Header  |  1995-02-15  |  5KB  |  283 lines

  1. /*
  2. **    termPickScreen.c
  3. **
  4. **    Simplified public screen selection routine
  5. **
  6. **    Copyright © 1990-1995 by Olaf `Olsen' Barthel
  7. **        All Rights Reserved
  8. */
  9.  
  10. #include "termGlobal.h"
  11.  
  12. enum    {    GAD_LIST=1,GAD_USE,GAD_CANCEL };
  13.  
  14.     /* BuildScreenList():
  15.      *
  16.      *    Build a private copy of the public screen list.
  17.      */
  18.  
  19. STATIC struct List *
  20. BuildScreenList(VOID)
  21. {
  22.     struct List *List,*PubScreenList;
  23.  
  24.         /* Get the list body. */
  25.  
  26.     if(List = (struct List *)AllocVecPooled(sizeof(struct List),MEMF_ANY))
  27.     {
  28.         NewList(List);
  29.  
  30.             /* Get access to the public screen list. */
  31.  
  32.         if(PubScreenList = LockPubScreenList())
  33.         {
  34.             struct Node *Next,*Node;
  35.  
  36.             Node = PubScreenList -> lh_Head;
  37.  
  38.                 /* Scan the list. */
  39.  
  40.             while(Next = Node -> ln_Succ)
  41.             {
  42.                     /* Don't include the current `term' public
  43.                      * screen name in it.
  44.                      */
  45.  
  46.                 if(strcmp(Node -> ln_Name,TermIDString))
  47.                 {
  48.                     struct Node *New = CreateNode(Node -> ln_Name);
  49.  
  50.                         /* Got a new node? */
  51.  
  52.                     if(New)
  53.                         AddTail(List,New);
  54.                 }
  55.  
  56.                 Node = Next;
  57.             }
  58.  
  59.             UnlockPubScreenList();
  60.         }
  61.  
  62.             /* In case the list happens to remain empty,
  63.              * include the Workbench screen in it.
  64.              */
  65.  
  66.         if(!List -> lh_Head -> ln_Succ)
  67.         {
  68.             struct Node *New = CreateNode("Workbench");
  69.  
  70.             if(New)
  71.                 AddTail(List,New);
  72.             else
  73.             {
  74.                 FreeVecPooled(List);
  75.  
  76.                 List = NULL;
  77.             }
  78.         }
  79.     }
  80.  
  81.     return(List);
  82. }
  83.  
  84.     /* PickScreen(STRPTR Name):
  85.      *
  86.      *    Your nice public screen selection routine.
  87.      */
  88.  
  89. BYTE __regargs
  90. PickScreen(struct Window *Window,STRPTR Name)
  91. {
  92.     struct List    *ScreenList;
  93.     BYTE         Result = FALSE;
  94.  
  95.     if(ScreenList = BuildScreenList())
  96.     {
  97.         struct LayoutHandle *Handle;
  98.  
  99.         if(Handle = LT_CreateHandleTags(Window -> WScreen,
  100.             LH_LocaleHook,    &LocaleHook,
  101.         TAG_DONE))
  102.         {
  103.             struct Window    *PanelWindow;
  104.             ULONG         Index = (ULONG)~0,i;
  105.             struct Node    *Node;
  106.  
  107.             for(Node = ScreenList -> lh_Head, i = 0 ; Node -> ln_Succ ; Node = Node -> ln_Succ, i++)
  108.             {
  109.                 if(!strcmp(Node -> ln_Name,Name))
  110.                 {
  111.                     Index = i;
  112.  
  113.                     break;
  114.                 }
  115.             }
  116.  
  117.             LT_New(Handle,
  118.                 LA_Type,    VERTICAL_KIND,
  119.             TAG_DONE);
  120.             {
  121.                 LT_New(Handle,
  122.                     LA_Type,    VERTICAL_KIND,
  123.                     LA_LabelID,    MSG_V36_1271,
  124.                 TAG_DONE);
  125.                 {
  126.                     LT_New(Handle,
  127.                         LA_Type,    LISTVIEW_KIND,
  128. /*                        LA_LabelID,    MSG_TERMPICKSCREEN_SCREEN_LIST_GAD,*/
  129.                         LA_Chars,    40,
  130.                         LA_ID,        GAD_LIST,
  131.                         LA_Lines,    10,
  132.                         LALV_MaxGrowY,    20,
  133.                         LALV_ResizeY,    TRUE,
  134.                         GTLV_Labels,    ScreenList,
  135.                         GTLV_Selected,    Index,
  136.                         LALV_Link,    NIL_LINK,
  137.                         LALV_CursorKey,    TRUE,
  138.                     TAG_DONE);
  139.  
  140.                     LT_EndGroup(Handle);
  141.                 }
  142.  
  143.                 LT_New(Handle,
  144.                     LA_Type,VERTICAL_KIND,
  145.                 TAG_DONE);
  146.                 {
  147.                     LT_New(Handle,
  148.                         LA_Type,    XBAR_KIND,
  149.                         LAXB_FullSize,    TRUE,
  150.                     TAG_DONE);
  151.  
  152.                     LT_EndGroup(Handle);
  153.                 }
  154.  
  155.                 LT_New(Handle,LA_Type,HORIZONTAL_KIND,
  156.                     LAGR_SameSize,    TRUE,
  157.                     LAGR_Spread,    TRUE,
  158.                 TAG_DONE);
  159.                 {
  160.                     LT_New(Handle,
  161.                         LA_Type,    BUTTON_KIND,
  162.                         LA_LabelID,    MSG_GLOBAL_USE_GAD,
  163.                         LA_ID,        GAD_USE,
  164.                         LABT_ReturnKey,    TRUE,
  165.                         LABT_ExtraFat,    TRUE,
  166.                     TAG_DONE);
  167.  
  168.                     LT_New(Handle,
  169.                         LA_Type,    BUTTON_KIND,
  170.                         LA_LabelID,    MSG_GLOBAL_CANCEL_GAD,
  171.                         LA_ID,        GAD_CANCEL,
  172.                         LABT_EscKey,    TRUE,
  173.                         LABT_ExtraFat,    TRUE,
  174.                     TAG_DONE);
  175.  
  176.                     LT_EndGroup(Handle);
  177.                 }
  178.  
  179.                 LT_EndGroup(Handle);
  180.             }
  181.  
  182.             if(PanelWindow = LT_Layout(Handle,LocaleString(MSG_TERMPICKSCREEN_SCREENS_TXT),NULL,0,0,IDCMP_CLOSEWINDOW,0,
  183.                 LAWN_HelpHook,        &GuideHook,
  184.                 LAWN_Parent,        Window,
  185.                 WA_DepthGadget,        TRUE,
  186.                 WA_CloseGadget,        TRUE,
  187.                 WA_DragBar,        TRUE,
  188.                 WA_RMBTrap,        TRUE,
  189.                 WA_Activate,        TRUE,
  190.             TAG_DONE))
  191.             {
  192.                 struct IntuiMessage    *Message;
  193.                 BOOLEAN             Done = FALSE;
  194.                 ULONG             MsgClass,
  195.                              MsgQualifier;
  196.                 UWORD             MsgCode;
  197.                 struct Gadget        *MsgGadget;
  198.  
  199.                 LT_ShowWindow(Handle,TRUE);
  200.  
  201.                 PushWindow(PanelWindow);
  202.  
  203.                 do
  204.                 {
  205.                     if(Wait(PORTMASK(PanelWindow -> UserPort) | SIG_BREAK) & SIG_BREAK)
  206.                         break;
  207.  
  208.                     while(Message = (struct IntuiMessage *)LT_GetIMsg(Handle))
  209.                     {
  210.                         MsgClass    = Message -> Class;
  211.                         MsgQualifier    = Message -> Qualifier;
  212.                         MsgCode        = Message -> Code;
  213.                         MsgGadget    = (struct Gadget *)Message -> IAddress;
  214.  
  215.                         LT_ReplyIMsg(Message);
  216.  
  217.                         if(MsgClass == IDCMP_CLOSEWINDOW)
  218.                             Done = TRUE;
  219.  
  220.                         if(MsgClass == IDCMP_GADGETUP)
  221.                         {
  222.                             switch(MsgGadget -> GadgetID)
  223.                             {
  224.                                 case GAD_USE:
  225.  
  226.                                     if(Index != (ULONG)~0)
  227.                                     {
  228.                                         struct Node *Node = GetListNode(Index,ScreenList);
  229.  
  230.                                         if(Node)
  231.                                         {
  232.                                             strcpy(Name,Node -> ln_Name);
  233.  
  234.                                             Result = TRUE;
  235.                                         }
  236.                                     }
  237.  
  238.                                     Done = TRUE;
  239.                                     break;
  240.  
  241.                                 case GAD_CANCEL:
  242.  
  243.                                     Done = TRUE;
  244.                                     break;
  245.  
  246.                                 case GAD_LIST:
  247.  
  248.                                     Index = MsgCode;
  249.                                     break;
  250.                             }
  251.                         }
  252.  
  253.                         if(MsgClass == IDCMP_IDCMPUPDATE)
  254.                         {
  255.                             struct Node *Node = GetListNode(Index = MsgCode,ScreenList);
  256.  
  257.                             if(Node)
  258.                             {
  259.                                 strcpy(Name,Node -> ln_Name);
  260.  
  261.                                 Done = Result = TRUE;
  262.  
  263.                                 LT_PressButton(Handle,GAD_USE);
  264.                             }
  265.                         }
  266.                     }
  267.                 }
  268.                 while(!Done);
  269.  
  270.                 PopWindow();
  271.             }
  272.  
  273.             LT_DeleteHandle(Handle);
  274.         }
  275.  
  276.         DeleteList(ScreenList);
  277.     }
  278.     else
  279.         DisplayBeep(Window -> WScreen);
  280.  
  281.     return(Result);
  282. }
  283.